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METHOD AND SYSTEM FOR NETWORK ACCESS OVER A 

LOW BANDWIDTH LINK 



RAPKCROTIND OF T HF TNVKNTTON 
TECHNICAL FIELD 

The invention relates to data communication networks. More particularly, the 
invention relates to transmitting information from a faster network to a data terminal via 
a slow network connection. 



DESCRIPTION OF THE PRIOR ART 

Electronic commercial and academic computer networks have been in existence 
for many years. An example of a commercial network is America On-Line. The largest 
and best-known electronic network is conmionly known as the Internet The Internet is 
a world-wide "network of networks" that is composed of thousands of interconnected 
computers and computer networks. 

The preferred protocol of conmiunications on the Internet is a set of standards 
and protocols, commonly referred to as TCP/IP. These TCP/IP protocols provide the 
means to establish a connection between two nodes on the network, and to 
subsequently transfer messages and data between these nodes. TCP (Transmission 
Control Protocol) provides the logical connection to ensure delivery of an entire 
message or file, while IP (Internet Protocol), provides the rouung mechanism. 

The majority of residential and commercial users of such computer networks 
(the clients) do not have a direct connection to the network. They subscribe to the 
services of an access provider, commonly called "Internet Service Provider" (ISP) in 
the case of the Internet. Clients use a personal computer or other terminal that is 
equipped with a data modem, to dial into the ISP connection service. 

Fig. 1 is a diagram of the topology of an Internet connection via an ISP, 
according to the prior art. The ISP maintains a network 10 that connects its clients to 
the Internet 26. This network includes the ISP backbone 12, which is an internal set of 
connected nodes. ISP backbones are typically connected to points of presence, known 
as POPs 14, and management (conu-ol) centers 16. The POP is typically the local 
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exchange that users dial into via modem. There are usually few management centers 
and many POPs in an ISP backbone. 

The ISP typically connects to the Internet via a Local Area Network (LAN) 28 at 
the management center. However, the ISP host may also be connected to the Internet 
via a Wide Area Network (WAN) such as the X.25 style PubUc Data Network (PDN). 
The LAN communicates with the Internet 26 through a physical, wide-bandwidth 
connection 30. However, the client does not connect to the LAN through such wide- 
bandwidth connection. Rather, the cUent accesses the Internet by using a computer 18 
with a modem 20 to dial up, through the public telephone system 22, another modem in 
a local POP 24. This modem-to-modem connection is a relatively slow, low bandwidth 

two-directional link. 

The ISP usually provides a relatively slow point-to-point (serial) two- 
dimensional link, through which the client communicates directly to the Internet, using 
the Internet standard TCP/IP protocols. Such serial link transfers digital data one bit 
after the other. The Recommended Standard-232 (RS-232) is the standard commonly 
followed for serial data transmission. (See, for example. Electronic Industries 
Association, EIA Standard RS-232-C, "Interface Between Data Terminal Equipment 
and Data Communications Equipment Employing Serial Binary Data Interchange", 
August 1969.) 

Point-to-point links are among the oldest methods of data communications and 
almost every host supports point-to-point connections. A long-distance point-to-point 
link is achieved by using a modem to establish a dial-up link between a display 
terminal, such as a personal computer, and the other host, such as a host located on the 
ISP site. 

The communication over the serial point-to-point line is in the form of 
encapsulated (framed) TCP/IP datagrams (data packets) using either Serial Line Internet 
Protocol (SLIP) or Point-to-Point protocol (PPP) packet framing. 

The SLIP protocol is described in IETF Network Working Group (J. Romkey), 
"A NONSTANDARD FOR TRANSMISSION OF IP DATAGRAMS OVER SERIAL 
LINES: SLIP ," Request for Comments: 1055 - June 1988. The PPP protocol is 
described in IETF Network Working Group (D. Perkins). "The Point-to-Point Protocol 
for the Transmission of Multi-Protocol Datagrams Over Point-to-Point Links," Request 
for Comments: 1171. SLIP transmits IP data packets over any serial link, such as a 
telephone line. It is generally used to provide Internet access to networks that support 
TCP/IP. PPP is a more conmion data link protocol that provides dial-up access over 
serial Unes. . 
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Fig. 2 is a diagram of a traditional Internet connection according to the prior art. 
To communicate on the Internet 26, an appliance or terminal (the client) 18 establishes a 
logical connection with a content provider. This connection is typically made using 
dial-up equipment, such as a modem 46 to connect to the public telephone system 22. 
5 The information transmitted over the telephone line is composed of PPP-wrapped 
TCP/IP data packets. Essentially, the ISP 10 is a transparent channel through which 
the client directly communicates with content providers, such as Web sites 51. 

There are several disadvantages to this prior art approach. One major 
disadvantage is that of cost and complexity. Each tenninal must be equipped with the 
10 ability to handle TCP/IP and PPP or SLIP protocols. This can require as much as 90 
Kbytes of code and 70 Kbytes of data. Another major disadvantage is that of 
bandwidth. The Internet protocol overhead must be transniitted through the slow serial 
link, thereby reducing the actual useful bandwidth. 

Yet another disadvantage is the need to duplicate, in each terminal, the code to 
15 deal with every possible type of data that may be transferred. Additionally, the 
established connection between the client and the Web server is recreated for every 
required file. This prevents a more general solution where conMionly fetched files or 
messages are cached. 

The World-Wide Web (Web) is an Internet client-server distributed information 
20 retrieval system. On the Web documents, menus, and indices are represented to the 
user as hypertext objects. Hypertext is a collection of documents containing 
cross-references or "links". These links enable the user, with the aid of an interactive 
browser program, to move from one document to another. 

The Web may be accessed through other types of devices than a computer, 
25 including personal data assistants, fax machines, and Internet-capable telephones. One 
device that can provide Internet access is the terminal described in M. Valentaten, B. 
Moeschen, Y. Friedman, Y.-T. Sidi, Z. Blkowsky, Z. Peleg , Multi-Mode Home 
Terminal System that Utilizes a Single Embedded General Purpose/DSP Processor and 
a Single Random Access Memory, U.S. Patent No. 5,259,940 (October 5, 1993). 
30 An internet access device, such as a modem-connected personal computer, 

generally uses a software application known as a Web browser to access the Web 
information available on the Internet, 5uch Web browsers, including Navigator, 
manufactured by Netscape Conmiunications Corporation of Mountain View, California, 
and Mosaic, owned by the National Center for Supercomputing Applications (NCSA) 
35 at the University of Illinois, Urbana-Champaign, use a direct connection to the Web 
over SLIP/PPP. Thus, all of the overhead, in particular the parallel protocol overhead, 
is over the slow link. 
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To mitigate the above-mentioned disadvantages, prior art solutions that do not 
require the display terminal to handle the TCP/IP protocol set have been used to access 
the Internet. One such solution is for the user to acquire a shell account on the ISP host 
computer. With a shell account, a simple text transfer protocol and a terminal-emulator 

5 program are used to permit the user to communicate with the Internet through the 
display terminal, using a text-only Web browser program. One such text-only Web 
browser is Lynx, developed by the University of Kansas and currently maintained by 
Foteos Macrides at the Worcester Foundation for Biological Research. However, the 
shell account approach is subject to the major disadvantage that only plain-text 

10 information, and not images, colors, and sounds can be viewed. 

Another prior art approach is that of the commercial Internet Web browser 
SlipKnot, developed by MicroMind, Inc. SlipKnot permits Web browsing through a 
serial link to a server, typically a Unix server, using a simple dial-in program. A 
TCP/IP stack is not required. When a user selects a hyperhnk using SlipKnot, a textual 

15 description of the hyperlink is u-ansferred to the ISP. SlipKnot uses the capabilities of 
the shell account to execute an "agent" program (such as Lynx) on the ISP machine. 
This agent fetches the requested multimedia file and uses a data-transfer program, such 
as xmodem, to transfer the file to the display terminal for display. 

However, SlipKnot can be inconvenient to use and install. Furthermore, 

20 because the agent program is invoked separately for each separate request, information 
transfer is inefficient and slow. The SUpKnot method can handle only one request at a 
time and allows only local caching on the client. 

It would therefore be an advantage to provide a method and system that 
improves the transfer of information from a faster network to a data terminal via a low- 

25 bandwidth link. It would be a further advantage if such method and system filters 
irrelevant Internet information prior to its transfer over the low-bandwidth link. It 
would be yet another advantage if such method and system reduces, if not entirely 
eliminates, protocol negotiation over the low-bandwidth link. 

30 SUMMARY Q|F THE INVENTION 

The invention provides a method and system for transmitting information from 
a faster network to a data terminal via a slower network connection. The preferred 
embodiment of the invention is adapted for use with any Internet terminal or access 
35 device, such as a telephone. A client connects to the Internet via an intermediary 
software program, known as the Gateway (GW). In the preferred embodiment of the 
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invention, the GW executes on a host computer of an ISP's Local Area Network 
(LAN. 

The client dials up a Remote Access Server located at the ISP's local point-of- 
presence. The Remote Access Server coimnunicates, via the ISP's backbone and 
5 using the TCP/IP network, with an authentication server. Initial authentication on the 
incoming caUs is performed and the logical connection to the GW is estabUshed. The 
GW, in turn, uses the ISP's communication network and the TCP/IP protocol to 
connect to the Internet. 

The GW thus mediates tiie data transfer between the Internet, such as the 
10 Web. and tiie client Internet terminal. The GW employs a point-to-point Internet 
protocol, the Gateway Interface Protocol (GWIP) to communicate with the client over 
the low-bandwidth link. The invention shifts the entire overhead of the Internet 
protocol stack to the GW, and does not involve tiie Internet terminal or tiie slow link 
between Internet terminal and GW. The Internet terminal needs no IP address. A 
15 single IP address is used by die GW to represent all Internet terminals. 

The GW makes and negotiates multiple Internet requests, in parallel, for 
information to be fetched and loaded from the Internet using the GWIP protocol. The 
GW parses all requests and forwards them to tiie appropriate Internet server for 
execution. The GW filters each received file according to file type, and multiplexes 
20 tiie resulting data stteams efficientiy over tiie single Unk to the Internet terminal, based 
on tiie current priority of each stream. This allows documents to be loaded in parallel 
witii tiieir associated images, resulting in a much improved perceived speed. These 
streams can be paused and resumed as desired, according to a predetermined or 
dynamic priority. Such parallel reuieval of multiple objects is performed over the 
25 slow link without the use and overhead of Internet protocols. 

The GW may also be used to convenientiy customize the Internet terminal. In 
one embodiment of tiie invention, a profile of tiie Internet terminal user is stored in tiie 
Internet terminal. The GW uses this profile to provide customized services, such as 
sending only tiiumbnail views of images, or not sending ceitain material. In anotiier 
30 embodiment of the invention, tiie GW serves as a software upgrade server. Using tiie 
GWIP protocol, a new firmware version can easily be uploaded, or a specialized 
device driver such as a printer driver uploaded as necessary. The invention may be 
used to upgrade or modify the graphical user interface of tiie Internet terminal. 

In an alternative embodiment of the invention, the GW performs off-line 
35 services, such as collecting e-mail, or conducting intelligent off-line searches. The 
GW can be used to cache commonly used information fetched from tiie Internet. In 
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one embodiment of the invention, the GW is used as a mechanism for ISPs to track 
and bill customers for the use of the internet connection. 

The invention is also readily adapted for use with Internet access devices that 
require different document formats and have different display capabilities, such as an 
Internet-compatible telephone, computer, a cellular phone, or a personal digital 
assistant having a wireless phone. In the preferred embodiment of the invention, the 
HTML layout is converted to a compressed equivalent of the HTML layout. 
Alternative embodiments of the invention do not convert the HTML layout, or convert 
the HTML to different screen formats. 

BRIEF DESCRIPTION OF THE DRAWINGS 



Fig. 1 is a diagram of the topology of an Internet connection via an ISP 
according to the prior art; 
15 Fig. 2 is a diagram of a traditional Internet connection according to the prior 

ait; 

Fig. 3 is a diagram of the GW architecture according to the invention; 

Fig. 4 is a diagram of the topology of an Internet connection via an ISP 
according to the invention; 
20 Fig. 5 is a diagram showing the topology of an Internet terminal connection to 

the Internet according to the invention; and 

Fig. 6 is a flow chart of the filtering process according to the invention. 



DETAILED DE SCRIPTION OF THE INVENTION 



The invention provides a method and system for transn:iitting information ftom 
a faster network to a data terminal via a slower network connection. 

The preferred embodiment of the invention is adapted for use with the Web 
technique described above. However, alternative embodiments of tiie invention are 
30 adapted for use with any Internet access device. Thus, \ht following discussion is 
provided for purposes of example and not as a limitation on the scope of the 
invention. 

The Web is usually accessed via telephone lines by a modem-connected 
computer, or Internet access terminal. The client dials up an ISP, for example using 
35 tiie PPP protocol. In turn, the ISP host establishes the connection to tiie Internet. 

In the invention, however, the client connects to the Internet via an 
intermediary software program, known as the Gateway (GW). The GW mediates the 
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data transfer between the Internet, such as the Web, and the cUent computer/Internet 
access terminal. The GW employs a point-to-point Internet protocol, the Gateway 
Interface Protocol (GWIP) to communicate with the client over the low-bandwidth 
link. The invention thereby shifts the entire overhead of the Internet protocol stack to 
the GW, and does not involve the Internet terminal or the slow Unk between Internet 
terminal and GW. 

Fig. 3 is a diagram of the GW architecmre according to the invention. The 
invention fi-amework includes a GW 42 that ftinctions as an intermediary between 
client devices 30, such as an Internet-compatible telephone, and content providers, 
such as Web sites 51. Therefore, the GW, integrated into the ISP network, mediates 
access to the Internet on behalf of its clients. 

Fig. 4 is a diagram of the topology of an Internet connection via an ISP 
according to the preferred embodiment of the invention. In the invention, the Internet 
terminal 30 uses the pubUc telephone system 22 to dial up a local POP 24 within the 
ISP backbone 12. The GW. which is integrated into the ISPs network 10. mediates 
access to the Internet on behalf of its clients. The GW is a seamless software addition 
to standard ISP network configurations. 

The ISP's E-mail servers 32. authentication servers 34. network management 
control 36. and proxy servers 38 are typically located at a management center 16. In 
the preferred embodiment of the invention, the GW 42 is also located at the 
management center. The GW preferably executes on a host computer of the ISP's 
Local Area Network (LAN) 40 with other computers and servers, such as the E-maU 
servers, network management servers, and authentication servers. However, the GW 
may also be executed by a dedicated server mediating between the LAN and the cUent. 

The cUent uses the Internet terminal 30 to dial and connect to a dial-up Remote 
Access Server 46 which is located at tiie ISP's local POP 24. This Remote Access 
Terminal Server communicates, via the ISP's backbone 12 and using the TCP/IP 
network 44. with an autiientication server 34. Initial authentication on the incoming 
calls is performed and the logical connection to tiie GW is established. The GW, in 
turn, uses a router 48 to connect to the Internet 26. 

Fig. 5 is a diagram showing the topology of an Internet terminal connection to 
the Internet according to tiie invention. The Internet terminal 30 uses a modem 50 to 
dial-up a modem 52 at the ISP's local POP.. This modem can be a hardware device 
tiiat is located internal or external to the Internet terminal, or can be an integrated 
software modem. This modem 52 transmits information from Oie client to the GW 42 
on the LAN. The GW uses Hypenext Transfer Protocol (HTTP) and TCP/IP 
protocol 60 to communicate, via a datalink 54 to the Internet 26. The Internet terminal 
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displays the information retrieved from the Internet on its display screen 56 using a 
browser application 58. 

The GW executes on a host computer with a physical, wide-bandwidth 
connection to the Internet. However, the cUent computer does not have such a wide- 

5 bandwidth connection to the Internet. Rather, the client computer must connect to the 
Internet through a low-bandwidth slow link. 

The GW employs an extremely simple point-to-point Internet protocol, 
referred to hereafter as the Gateway Interface Protocol (GWIP) to communicate with 
the Internet terminal over this relatively slow, low-bandwidth link. The GW then 

10 negotiates Internet requests on behalf of the Internet ternunal over the fast, wide- 
bandwidth link. The ftjnction of the GW is, therefore, to serve as an agent or 
representative of the Internet terminal, and to negotiate Internet access on its behalf. 
As a result, the entire overhead of the Internet protocol stack is handled by tiie GW, 
and does not involve the Internet terminal or the slow Unk between Internet terminal 

15 and GW. 

A request is a signal sent from a transmitting station to a receiving station 
requesting permission to transmit information. This permission is given with a 
response. The GW examines, pre-processes and modifies (filters) the Internet 
terminal' s Internet requests and responses to improve performance and utility. The 
20 invention is particularly useful in tiie context of Internet display terminals, such as the 
Internet-compatible telephone, having a low bandwidtii connection and limited storage 
capabilities. 

A Web page is encoded in Hypertext Markup Language (HTML). An HTML 
document is a plain-text (ASCH) file that uses tags to denote the various elements in 
25 the document. An element may include an attribute, which is additional information 
that is included between tags. 

HTML can be used to link text and/or images, such as icons, to another 
document or section of a document. The user activates a Unk by clicking on it, and 
the linked database is directly accessed. Links are used to access related information, 
30 or to contact a person or entity. However, information on a Web page must have the 
requisite HTML tags to be an active link. 

In the invention, the client selects a hyperiink request for a text or image file 
on the Web. The Internet terminal forwards die request to the GW using the GWIP 
protocol. If the page in question contains embedded images, die Internet ternunal 
35 forwards additional, parallel requests for the images as well. 

The GW simplifies the transmission of requested Internet data, as compared to 
the prior art. Because the GW handles die protocol negotiation with the Internet data 
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server, it does not need to be negotiated over the slow link. The design of the Internet 
terminal may therefore be simplified and the amount of traffic over the slow link 
reduced. Experimental data has shown that the GW is approximately 20% more 
efficient than a prior art TCP/IP stack connection over PPP. 
5 In the preferred embodiment of the invention, the GW also pre-processes, 

filters and simplifies the acmal data by reducing the amount information that is 
irrelevant to the display environment that has been identified by the GW. This 
infomiation can be reduced by such methods as stripping out information, optimizing, 
compressing, and by generally reducing size. Fig. 6 is a flowchart of the filtering 
10 process according to the invention. The client initiates a request to the GW for 
information from the Internet (100). The GW either identifies (105) or is pre- 
programmed with a client's amibutes. 

The GW then negotiates the request with the Intemet (110) and retrieves the 
requested information (115). The GW fdters the Intemet information by reducing the 
15 amount of information that is not relevant to the client's attributes (120). The GW 
then sends to the client only that information which is needed (120). Therefore, 
bandwidth is not wasted on irrelevant or useless information and the client's 
processor does not have to process the unnecessary information. The size or power 
of the Intemet terminal processor can therefore be reduced as compared to the prior 
20 an, resulting in cost and maintenance savings to the client. 

For example, extra (redundant) color information is removed from images, or 
is reduced according to the physical characteristics of the display. Thus, if the 
receiving intemet access terminal has a gray scale display, there is no need to uransmit 
the color-related information over the slow link. 
25 The GW reduces the amount of this irrelevant information in the HTML 

coding of a Web page before the page is transmitted over the low bandwidth link to 
the client. Data pages can also be stripped of redimdant blank characters, or converted 
to a more efficiently compressed equivalent data format. This results in improved 
usage of the bandwidth of the slow link. Experimental data has shown that by pre- 
30 processing, filtering, and simplifying the actual data, the GW is approximately 10% 
more efficient than the prior art. 

The invention uses a low-power compression/ decompression scheme, such 
as run-length encoding (RLE). This data compression scheme converts a "run" of 
identical characters into a code. Using this two-dimensional run-length compression, 
35 the GW compresses data on the fly without a lot of complex looking-back or looking- 
ahead. Such two-dimensional run-length compression looks in both vertical and 
horizontal directions at any given coordinate. 
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The GW makes and negotiates multiple Internet requests, in parallel, for 
information to be fetched and loaded from the Internet using the GWP protocol. The 
GW parses all requests and forwards them to the appropriate Internet server for 
execution. The GW filters each received file according to file type, and multiplexes 
the resulting data streams efficiendy over the single link to the Internet terminal, based 
on the current priority of each stream. This allows documents to be loaded in parallel 
with their associated images, resulting in a much improved perceived speed. These 
streams can be paused and resumed as desired. Such parallel retrieval of multiple 
objects is performed over the slow link without the use and overhead of Internet 
protocols. 

The GW may also be used to conveniently customize the Internet terminal. In 
one embodiment of the invention, a profile of the Internet terminal user is stored in the 
Internet terminal. The GW uses this profile to provide customized services, such as 
sending only thumbnail views of images, or not sending certain material. In another 
embodiment of the invention, the GW serves as a software upgrade server. Using the 
GWIP protocol, a new firmware version can easily be uploaded , or a specialized 
device driver such as a printer driver uploaded as necessary. 

Furthermore, the GW may be used with the integrated graphical user interface 
and slide-up window described in Method And Apparatus For Organizing And 
Displaying Internet And Telephone Information , also assigned to InfoGear 
Technology Corp. of Redwood City, CA, filed in the U.S. Patent and Trademark 
Office herewith and incorporated as a part hereof. The invention may be used to 
upgrade or modify the integrated GUI as described in the abovementioned applicadon. 

In an alternative embodiment of the invention, the GW is used as an off-line 
agent. Thus, in simations where the Internet terminal is connected via a link which is 
not always available, as with dial-up phone lines, the GW performs off-line services, 
such as collecting e-mail, or conducting intelligent off-line searches. 

The GW can be used to cache commonly used information. A GW that serves 
multiple Internet terminals can cache the information fetched from the Internet. This 
reduces overall network access and improves responsiveness. For example, the GW 
can maintain a local name-to-IP address table. 

In one embodiment of the invention, the GW is used as a mechanism for ISPs 
to track and biU customers for the use of the internet connection. For example, the 
GW can keep track of charges that the user accepts for the privilege of accessing 
certain copyrighted material. 

The GWIP protocol is a high-level (session layer), full duplex, point-to-point 
data transfer protocol. It is used between a single client, such as the Intemet- 
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compatible telephone, and a single server running the GW. The entire GWP protocol 
may be encapsulated by lower-level network transport protocols, such as 
V42A^42.bis, X.25, or even PPP/TCP/IP. These encapsulating protocols may add 
compression, encryption and reliability, as required. 

5 GWIP assumes that the underlying transport is error free. It is optimized to 

allow efficient asynchronous data transfer over a serial sequential medium, such as a 
relatively slow serial modem line. 

The GWIP protocol consists of small data packets, typically about 250 bytes, 
which provide the capability for multiple interleaved data streams in both directions. 

10 There is no concept of "embedded," "escaped," or "out-of-band" control characters; 
all control information is in the form of complete GWIP packets. The GWIP 
described below is optimized for use with an Internet-compatible telephone. 
However, one skilled in the art will readily appreciate that the GWIP may be adapted 
to other Internet terminals, including different types of Internet-compatible telephones. 

15 Table 1 describes the GWIP protocol structure. All GWIP packets start with a 

DLE character, followed by a byte, designated "len," with.the length of the rest of the 
packet. The DLE character is a non-printable character that is used to indicate a 
begiiuiing of a message. This convention provides a small measure of error-detecting 
redundancy over a normally error-free transport layer. 



20 



Idle | ten t data 

TABLE 1 



The third byte of a GWIP packet ("/ " in Table 1, above) always indicates the packet type. 
25 Additional data fields are optional. The packet type determines the packet destination and 
stmcture. Multiple-byte integer values are transnoitted in network byte order (MOST significant 
byte first). 

In most cases, the Internet terminal issues a request (a GWIP command), to which the 
GW responds by issuing one or more GWIP response packets. A request is always associated 
30 with a new stream. A stream comprises multiple packets that are logically associated via a 
common stream handle. A handle is an unsigned integer between 0 and 254 (255 is reserved). 
Responses use the same handle as the original request. Streams are sometimes also known as 
virtual channels. The GW may also issue spontaneous status and service messages that are 
related to one of the open su-eams. 
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A connection between the Internet terminal and the GW host (server) is always initiated 
by the client. As soon as a data connection is established, a configuration dependent exchange 
takes place between the Internet terminal and the GW host. This results in the estabhshment of 
a logical link between the Internet terminal and the GW software. 

At this point, the GW waits for a special sequence of four bytes, that indicates the 
version of the GWIP protocol supported by the Internet terminal. The structure of this 
sequence is shown in Table 2, as follows: 



DLE 


mcgor 


minor 


ETX j 



10 



TABLE 2 



The first byte of the sequence is the DLE character and the second byte is a (positive) major 
version number. The third byte is the minor version number, and the fourth byte the ETX 
character. ETX is a non-printable character that is frequently used to indicate the end of a 
15 message. 

The discussion in this application describes an exemplary version of the GWIP protocol 
specification. One skilled in the an will readily recognize that other versions of the GWIP may 
be implemented in the invention. Thus, the following discussion is provided for purposes of 
example and not as a limitation on the scope of the invention. 

20 The GW ignores all bytes that precede this version sequence. When it receives a valid 

version sequence, it returns a STAT.OK GW.STATUS packet (see below) to the Internet 
terminal and prepares to handle a regular GWIP session. The Internet terminal repeats the 
version sequence at, for example, 5-second intervals, until it receives the GW_STATUS 
packet. The Internet terminal disconnects if no valid response is received after three attempts. 

25 This disconnection resets the GW. 

Unless specified differently, the word "command" indicates a packet that originates 
from the Internet terminal terminal; the word "response" refers to a GW initiated packet, types. 
Most GWIP packet types are used both as commands and response, but may have different 
formats. 

30 Some commands, such as GW.LOGIN, GW.CONHG and GW_ANCHOR, have 

additional command fields. Table 3 shows the GW_LOGIN command. Command fields are 
pairs of the field "name" (a one byte enumerator), followed by the field "value." Each 
command field is preceded by a one-byte length field, indicating the total length of the 
command field. 

35 
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DLE 



len 



type 



authentication fields 



TABLE 3 



Every GWIP session starts with a GW_LOGIN Internet terminal command. This authenticates 
5 the Internet terminal. The authentication includes the fields listed in Table 4: 



field 


na^me 


value length (bytes) 


Internet terminal serial ID 
(unique) 


LOG_SERID 


4 


boot-section/Intemet terminal 
version id 


LOG^OOTVER 


4 


firmware version id 


LOG.FIRMVER 


4 


user name (id) 


LOG.USER 


string 


password 


LOG.PASSWD 


string 


6. . 







TABLE 4 

10 The GW replies with a GW_STATUS response message, with a status STAT_OK, followed 
by an optional GW_SERVICE message. Any other response, or no response at all, causes the 
Internet temiinal to disconnect. 

The only valid commands after GW.LOGIN are GW.CONHG, GW_LOGOUT, and 
GW_UPGRADE. The GW_LOGOUT command packet is shown in Table 5. 

15 



DLE 



len 



type 



TABLE 5 



The prdper way for an Internet terminal to terminate a session is to send a GW_LOG0UT 
20 command, and then to wait for the GW_LOGOUT response. A session may also end as a 
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result of the Internet terminal disconnecting deliberately, or as a result of a communication fault 
or other error. 

The GW.LOGOUT response to the Internet terminal GW.LOGOUT command is 
shown in Table 6. The log out message is optional. After receiving the GW„LOGOUT 
5 response, the Internet terminal disconnects from the Une. 



DLE 



len 



type 



logout msg 



TABLE 6 



10 A GW_CONFIG command is sent by the Internet terminal to the GW immediately after the 
GW.LOGIN command. The GW_CONFIG command may be repeated at any time after the 
GW_LOGIN command. GW_CONFIG informs the GW about the user's 
preference/configuration table, including the language in which service messages must be sent, 
image preference opdons, and time out values. All values must be valid. The GW_CONFIG 

15 command is shown in Table 7. 



DLE 



len 



type 



PI_type 



configuration fields 



TABLE 7 



20 The one-byte Pl.type field determines the plug-in or GW sub-system that is concerned with 
these configuration values. Typically, the Internet terminal will send a number of 
GW^CONFIG commands, one for each type of sub-system or plug-in, whenever the 
configuration on the Internet terminal is changed by the user. Accepted values for this field 
include PI_EMAIL, PI_WEB and PI_GEN. The configuration fields listed in Table 8 are 

25 defmed: 
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field 


name 


value lengih(bytes) 


used by 


font size 


CONHG.FONT 


1 


PI.GEN 


image display method 


CONHG.IMG 


1 


PI.WEB 


max image size to receive 


CONHG.MAX.IMG.SIZE 


2 


PI_WEB 


cache refresh options 


CONHG.CACHE 


4 


PI_GEN 


time out preference 


CONHG.TIMEOUT 


4 


PI.GEN 


language 


CONHG.LANG 


1 


PI.GEN 


Qalcoc lllTiC 5iyic 


CONFIG DATE 


1 


PI.GEN 


email user id 


CONHG.EUSER 


string 


PI.EMAI 
L 


email password 


CONHG.EPASSWD 


string 


PI.EMAI 
L 


6. 









TABLE 8 



5 The GW responds with a GW_CONFIG response to confirm receipt of the GW.CONFIG 
command. The Internet terminal does not issue any other type of commands before it receives 
the GW.CONHG response. The GW.CONHG conmiand is thus a synchronization point 
between the Internet terminal and the GW. 

A GW.ANCHOR conmiand is an Intemet terminal request for a new hypertext/image 

10 file. In an HTML document, the anchor is the format codes that are used to define a link to 
another page. The handle (/i ) field identifies the data stream and relates the request with 
subsequent GW response packets. The 2-byte "width" field indicates the width of the pane, in 
pixels, in which the information will be displayed. This conmiand packet is followed by one or 
more GW.DATA packets that include the anchor Uniform Resource Locator (URL), and is 

15 terminated by a GW.EOF packet. The GW responds with a GW.ANCHOR response, 
followed by GW.DATA packets, terminated by GW.EOF. The GW.ANCHOR command is 
given in Table 9. 
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DLE 



len 



type 



width 



TABLE 9 



A GW_REFRESH command is an Internet terminal request for the re-transmission of a 
5 hypertext/image document that is partially or fully in the Internet terminal cache. The handle ( h 
) field identifies the data stream and relates the request with subsequent GW response packets. 
The 2-byte "width" field indicates the width of the pane, in pixels, in which the information will 
be displayed. THe GW_REFRESH command is shown in Table 10. 



DLE 


len 


type 


h 


width 


skip-len 


creation date 



10 

TABLE 10 

The 2-byte "skip-len" field indicates how many data bytes must be skipped by the GW before 
sending the actual data. This is useful if a file was partially received and cached by the Internet 

15 terminal in a previous transmission, and does not need to be fully re-transmitted. 

The 6-byte "creation date" field indicates the creation date of the currently cached 
document. This conraiand packet is followed by one or more GW_DATA packets that include 
the anchor URL, and is terminated by a GW_EOF packet. 

The GW responds with a GW_ANCHOR response. If the file in the cache is up-to- 

20 date, the AN.CACHE.VALIDITY field of the GW.ANCHOR header will indicate that the 
cache is up-to-date (CACHE.VALID). Otherwise, the AN.CONTENT field will be 
CACHE.REPLACE or CACHE.DONT, and the value of skip-len will be ignored and the 
entire file will be re-transmitted. The GW_ANCHOR response will be followed by zero or 
more appropriate GW^DATA packets, and terminated by a GW^EOF. 

25 A GW.POST command is a form-request, transmitted via the HTTP POST method. 

The handle ( h ) field identifies the data stream and optionally relates the request with GW 
response packets. The GW responds with a GW_ANCHOR response, with a 
AN_CACHE_VALIDITY field of value CACHE.DONT, followed by GW.DATA packets. 
Responses to GW_POST are never cached. This command packet is followed by one or more 

30 GW_DATA packets that include the anchor URL and the posted text, and is terminated by a 
GW_EOF packet. The GW_POST command is given in Table 11. 
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DLE 


len 


type 


h 


width 



TABLE 11 



The GW indicates its intention to send the requested GW_ANCHOR or GW-POST information 
by responding with a GW_ANCHOR response. A relatively long time may pass between the 
GW_ANCHOR or GW_POST command and the GW_ANCHOR response, due to network 
delays. The header information may include the creation data/time, content type, compression 
and display method. The GW_ANCHOR response is given in Table 12. 



10 



DLE 



len 



type 



hdr info fields 



15 



Table 12 



The following anchor fields are defined: 



field 


name 


value length (bytes) 


creation time-stamp 


AN.CREATION 


4 (time_t) 


cache validity 


an.cache validity 


1 


content type 


AN_CONTENT 


1 


0. 







TABLE 13 



The GW then follows this with a sequence of GW_DATA response packets, terminated by a 
20 GW.EOF response. (Also see GW_ACK, described below), if a file cannot be retrieved, or if 

there is an unreasonably long time-out, the Internet terminal will usually cancel the 

GW_ANCHOR request via a GW_ENDSTREAM conomand. 

GW_DATA packets are used to send data streams, such as bitmap data, from the 

Internet terminal to the GW, or vice-versa. Each GW.DATA packet contains a handle that 
25 relates this packet to the specific stream. Data streams are terminated by a GW_EOF packet. 
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An infonnational percent byte, with a value between 1 and 100, indicates an estimated 
percentage of how much has been transmitted, including the package. A percent of 0% 
indicates that the sender does not know, or does not care to compute, the estimated percentage. 
The GW_DATA packet is given in Table 14. 



5 



DUE 


len 


type 


h 1 % 


data... 



TABLE 14 



The Internet terminal acknowledges each received data-packet of type GW.DATA by sending a 
10 GW_ACK command. This allows the GW to send another packet, without overflowing the 
Internet terminal input buffers, and prevents unwanted data from piling up in internal UNIX 
(host) serial driver and modem buffers. The Internet terminal may also, at regular time 
intervals, send GW_ACK commands to the GW to indicate that it is alive. GW_DATA packets 
sent by the Internet terminal to the GW are not acknowledged by the GW. The GW_ACK 
15 command is shown in Table 15. 



DLE 


len 


type 


h 



TABLE 15 



20 The GW_PRI command is provided to the GW to recommend the priority order for the 
transmission of packets of concurrent existing streams. The priority is provided in "pri," a one- 
byte non-negative value. The GW does not echo these commands. Initially, a stream is of 
priority ten. The GW_PRI command is given in Table 16. 



DLE 



len 



type 



pn 



25 



TABLE 16 



A priority of zero indicates that the stream is out of sight. This is usually, tme for images, when 
the user scrolls the screen. The GW sends data of all higher priority data streams first, in 
30 round-robin fashion, and only then sends data packets for lower priority streams. In the 
preferred embodiment of the invention, the values zero and ten only are used. However, 
alternative embodiments of the invention may use any appropriate priority values. 
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While the Web uses HTML coding for documents, the invention is also readily adapted 
for use with Internet access devices that require different document formats. In the preferred 
embodiment of the invention, the HTML layout is converted to an equivalent of the HTML 
layout. Alternative embodiments of the invendon do not convert the HTML layout, or convert 
5 the HTML to different browser formats. For example, an HTML page can be converted into 
formats accessible by a Web telephone, a cellular phone, or a personal digital assistant having a 
wireless phone. 

The layout conversion is performed, for example, by the server, cUent, Internet-capable 
telephone, Internet access device, or by a computer networked to the Internet-capable telephone 
10 or Internet access device. Further, such conversion may be an HTML-to-HTML conversion, 
for example as provided by a plug-in that operates in a connection with a conventional Web 
browser, such as Navigator, manufactured by Netscape Communications Corporation of 
Mountain View, California. 

One embodiment of the invention is upgradeable via downloading from the Web. The 
15 HTML coding may thereby be readily modified to provide new features, update existing 
features, or to comply with different protocols. This HTML is then translated, as necessary. 

The telephone numbers on a displayed Web page may be iconified and dialed, for 
example, as described in Method And Apparatus For Iconifying And Automatically Dialing 
Telephone Numbers Which Appear On A Web Page, also assigned to InfoGear Technology 
20 Corp. of Redwood City, CA, filed in the U.S. Patent and Trademark Office herewith and 
incorporated as a part hereof. These iconified telephone numbers may be added to an address 
book maintained as part of the invention. 

Although the invention is described herein with reference to the preferred embodiment, 
one skilled in the art will readily appreciate that other appUcations may be substituted for those 
25 set forth herein without departing from the spirit and scope of the present invention. 

For example, while the Preferred embodiment of the invention is adapted for use with a 
serial link, the teachings of the invention are readily applicable to any type of slow link. 
Accordingly, the invention should only be hmited by the Claims included below. 



19 



QMCrw^in. ^w^- 00100QPA? I > 



wo 99/19988 



PCT/US98/19451 



CLAIMS 

1 . A method for accessing network information during a communications session, 

5 comprising the steps of: 

accessing a host via a slow link using an Internet terminal; 

the host negotiating an Internet connection on behalf of said Internet terminal with a 
software application integrated into said host; and 

said software application using an interface protocol to transfer data from said Internet 
10 connection to and from said internet terminal, thereby mediating data transfer between the 
Internet and said Internet terminal. 

2 . The method of Claim 1 , further comprising the step of said software application filtering 
said Internet data from said Internet connection to reduce the amount of data that is irrelevant to 

15 said Internet tenninal's attributes. 

3. The method of Claim 1, further comprising the step of said software application 
stripping redundant characters from said Internet data. 

20 4. The method of Claim 1, further comprising the step of said software application 
converting said Internet data to a compressed equivalent data format. 

5 . The method of Claim 1 , further comprising the steps of: 

said software application using said interface protocol to make and negotiate multiple 

25 Internet requests, in parallel; 

said software application parsing and forwarding said requests to an Internet server for 

execution; 

said software application filtering data received from the Internet in response to said 
request and according to file type; and 
30 said software application multiplexing said filtered data over said slow link to said 

Internet terminal. 

6 . The method of Claim 1 , further comprising the steps of: 

said Internet terminal storing a profile of a user of said Internet terminal; and 
35 said software appUcation using said profile to customize said Internet data sent to said 

internet terminal. 

20 
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7 . The method of Claim 1, further comprising the step of said software apphcation using 
said interface protocol to upload data to upgrade said Internet terminal. 

8 . The method of Claim 1, wherein said software application is an off-line agent for said 
5 Internet terminal. 

9 . The method of Claim 1 , further comprising the step of said software application caching 
information conraionly used by said Internet terminal. 

10 10. The method of Claim 1, further comprising the step of said software application 
tracking charges accruing to said Internet terminal as a result of said Internet connection. 

11. The method of Claim 1, wherein said Internet terminal is an Internet-compatible 
telephone. 

15 

12. A method for accessing network information during a communications session, 
comprising the steps of: 

accessing a host via a slow link using an Internet tenninal; 

a software application integrated into said host negotiating an Internet connection on 
20 behalf of said internet terminal; 

said software application using an interface protocol to transfer data from said Internet 
connection to and fi^om said Internet terminal; 

said software application using said interface protocol to make and negotiate multiple 
Intemet requests, in parallel; 
25 said software application parsing and forwarding said requests to an Intemet server for 

execution; 

said software application filtering data received from the Intemet in response to said 
request according to file type; 

said software application reducing the amount of said Intemet data that is irrelevant to 
30 said Intemet temdnal's attributes; and 

said software application multiplexing said filtered data over said slow link to said 
Intemet temiinal. 

1 3 . The method of Claim 12, further comprising the steps of: 
35 said Intemet temiinal storing a profile of a user of said Intemet terminal; and 

said software application using said profile to customize said Intemet data sent to said 
Intemet terminal. 
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14. The method of Claim 12, further comprising the step of said software application using 
said interface protocol to upload data to upgrade said Intemet terminal. 

5 15. The method of Claim 12, wherein said software application is an off-line agent for said 
Intemet terminal. 

16. The method of Claim 12, further comprising the step of said software application 
caching information commonly used by said Intemet terniinal. 

10 

17. The method of Claim 12, further comprising the step of said software application 
tracking charges accruing to said user of said Intemet terminal as a result of said Intemet 
connection. 

15 18. The method of Claim 12, further comprising the step of. said software application 
stripping redundant characters from said Intemet data. 

19. The method of Claim 12, further comprising the step of said software application 
converting said Intemet data to a compressed equivalent data format. 

20 

20. The method of Claim 12, wherein said Intemet terminal is an Internet-compatible 
telephone. 

21. A system for accessing network information during a communications session, 

25 comprising: 

an Intemet terminal for accessing a host via a slow link;and 

a software application integrated into said host for negotiating an Intemet connection on 
behalf of said Intemet terminal; 

wherein said software application uses an interface protocol to transfer data from said 
30 Internet connection to and from said Intemet terminal. 

22. The system of Claim 21, further comprising a filtering module in said software 
application for filtering said Intemet data from said Intemet connection to strip out data that is 
irrelevant to said Intemet appliance's attributes. 

35 

23. The system of Claim 21, furtiier comprising a stripping module in said software 
application for stripping redundant characters from said Intemet data. 
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24. The system of Claim 21, further comprising a compression module in said software 
application for converting said Internet data to a compressed equivalent data format. 

5 25 . The system of Claim 2 1 , further comprising: 

a parallel request module in said software application for using said interface protocol to 
make and negotiate multiple Internet requests, in parallel; 

a parsing module in said software application for parsing and forwarding said requests 
to an Internet server for execution; 
10 a file type module in said software application for filtering data received from the 

Internet in response to said request according to file type; and 

a multiplexer module in said software application for multiplexing said filtered data over 
said slow link to said Internet terminal. 

15 26. The system of Claim 21, ftmher comprising; 

a storage module in said Internet tenninal for storing a profile of a user of said Internet 
temunal; and 

a customizing module in said software application for using said profile to custonuze 
said Internet data sent to said Internet terminal. 

20 

27. The system of Claim 21, further comprising an upgrade module in said software 
application for using said interface protocol to upload data to upgrade said Internet terminal. 

28 . The system of Claim 2 1 , wherein said software application is an off-line agent for said 
25 Internet terminal. 

29. The system of Claim 21, further comprising a cache in said software application for 
caching information commonly used by said Internet terminal. 

30 30. The system of Claim 21, further comprising a tracking module in said software 
apphcation for uracking charges accruing to said client as a result of said Internet connection. 

31. The system of Claim 21, further comprising a stripping module in said software 
application for stripping redundant characters from said Internet data. 

35 

32. The system of Claim 21, further comprising a compression module in said software 
application for converting said Internet data to a compressed equivalent data format. 

23 
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33. The system of Claim 21, wherein said Iniemei terminal is an Internet-compatible 
telephone. 

34. An access terminal, comprising; 

an Internet-compatible telephone for receiving and displaying a Web page; and 
a software module integrated into an Internet Service Provider for connecting said 
Internet-compatible telephone to the Internet; 

wherein said software module mediates data uransfer between the Internet and said Internet- 
compatible telephone. 



24 



wo 99/19988 



PCT/US98/19451 




wo 99/19988 



2/6 



PCTAJS98/19451 



26- 



r I — ■— — 



0| 



c 



Access Provider 

(ISP) 



10 



1 



Modem 
46-^RAS 



y-22 

PSTN O^ffl 



client 
terminal 



PPP 

encapsulated infonnation 



web site-^s 



51 



7 



Traditional Internet Connection 



FIG, 2 

(PRIORART) 



wo 99/19988 



3/6 



PCT/US98/19451 




IPhone 
client 
terminal 



C3WIP 
Protocol 



GW Architecture 



FIG. 3 



wo 99/19988 



PCT/US98/19451 



4/6 




wo 99/19988 



5/6 



PCT/US98/19451 



58 



Browser 



- I MODEM I +' 



56 
-30 
-50 



MODEM f 



52 




Server Gear 



HTTP/TCP-IP 



Data I ink/Physical 



£2 



The Internet 



-42 
-60 
-54 



-26 



FIG. 5 



wo 99/19988 



PCT/US98/19451 



6/6 







A'" 


CLIENT 
REQUESTS 
INFORMATION 




GW IDENTIFIES 
CLIENT 
ATTRIBUTES 








A" 




GW NEGOTIATES 
REQUEST WITH 
INTERNET 






A" 




INFORMATION 
RETURNED TO GW 






A'' 




GW STRIPS 
IRRELEVANT 
INFORMATION 






r 




INFORMATION 
TRANSMITTED 
TO CLIENT 



125 



FIG. 6 



PCX 



WORLD INTEUXCTUAL PROPERTY ORGANIZATION 
International Bureau 





(21) International implication Number: PCT/US98/ 19451 

(22) International Filing Date: 17 September 1998 (17.09.98) 



(30) Priority Data: 
08/948^34 



9 October 1997 (09.10.97) 



US 



(71) AppUcant: INFOGEAR TECHNOLOGY CORPORATION 

[USAJS]; Suite 200, 2055 Woodside Road, Redwood City, 
CA 94061 (US). 

(72) Inventors: BENDELAC, Chaim; Yekuticl Adam Street lb. 

44282 Kfar-Saba (BL). BITTMAN, Ran, M.; Hakneset 
Hagdola Street 20. 62917 Tel Aviv (IL). SAMBURSKI, 
Kobi; Ig*al Alon Street 30b, 46324 Herzliya (IL). 

(74) Agents: GLENN, Michael, A. et al.; Law Offices of Michael 
A. Glenn, P.O. Box 7831. Mcnlo Park, CA 94026 (US). 



(81) Designated States: AL, AU. BA, BB, BG, BR, CA^ CN. CU, 
^31) ^'^^^ ^ ^ ^ ^ js jp ^ KR^ Lc, LK, LR, 

LT, LV, MG. MK, MN. MX, NO. NZ, PU RO. SG SI SIC, 
SL, TO, TT, UA. UZ, VN, YU, ARIPO patent (GH, GM. 
KE, Ls! MW, SD, SZ, UG, ZW), Eurasian patent (AM, AZ. 
BY KG, Kzl MD, RU, TJ, TM), European patent (AT, BE, 
Ch! CY, DE, DK, ES, R FR, GB, GR, IE, IT, LU, MC, 
NL, PT; SE), OAPI patent (BF, BJ, CF. CG. CI. CM, GA, 
GN, GW, ML, MR, NE, SN, TO. TG). 



Published 

With international search report. 

Before the expiration of the time limit for amending the claims 
and to be republished in the event of the receipt of amendments, 

m\ Date of publication of the international search report: 

^ ' 10 September 1999 (10.09.99) 



(54) Tide: METHOD AND SYSTEM FOR NETWORK ACCESS OVER A LOW BANDWIDTH LINK 

'22 



26- 



web site-4^ 

17- 



(ISP) 




GW 




I 



IP hone 
client 
terminal 



42 



GWIP 
Protocol 



GW Architecture 



(57) Abstract 

A method and svstem are provided for transmitting infotroation from a faster network to a data teiminal via a slower networic 

P^t«T(GWIP) to commui^toite with the client over the low-bandwidth link. The invenuon shifts the ent«e "^/^J^^^^^^ 
m^S S «) Ae GW and does not involve the Internet tenninal or the slow link between Intenwt terminal and G^. The GW mak« 
KgoSL multiple internet requests, in parallel, and multiplexes the resulting da«a ^^'Sft^^^S^ 
with tteir associated images. The GW may also be used to conveniently customize orupgrade the Internet ^"^j^-J*^/^ P*" 
T-£ lcMccs and caches commonly u«d information fetched from the Internet, m mvcnaon is also readily adapted for use with 
Internet access devices that require different document formats. 



FOR THE PURPOSES OF INFORMATION ONLY 
Codes used to identify States patty to the PCT on the front pages of pamphlets publishing international applications under the PCT. 



AL 


Albania 


ES 


AM 


Annenia 


FI 


AT 


Austria 


FR 


AU 


Australia 


GA 


AZ 


Azeifoaijan 


GB 


BA 


Bosnia and Hcizegovina 


GE 


BB 


Bazbados 


GH 


BE 


Belgium 


GN 


BF 


Burkina Faso 


GR 


EG 


Bulgaria 


HU 


BJ 


Benin 


IE 


BR 


Brazil 


IL 


BY 


Belarus 


IS 


CA 


Canada 


IT 


CF 


Central African Republic 


JP 


CG 


Congo 


KE 


CH 


Switzerland . 


KG 


CI 


C6ie d'lvoire 


KF 


CM 


Cameroon 




CN 


China 


KR 


cu 


Cuba 


KZ 


cz 


Czech Republic 


LC 


DE 


Germany 


U 


DK 


Denmark 


LK 


EE 


Esiooia 


LR 



Spain 
Finland 
France 
Gabon 

United Kingdom 

Georgia 

Ghana 

Guinea 

Greece 

Hungary 

Ireland 

Israel 

Iceland 

Italy 

Japan 

Kenya 

Kyrgyzstan 

Democratic People's 

Republic of Korea 

Republic of Korea 

Kazakstan 

Saint Lucia 

Liechtenstera 

Sri Lanka 

Liberia 



LS 

LT 

LU 

LV 

MC 

MD 

MG 

MK 

ML 
MN 
MR 
MW 
MX 
NE 
NL 
NO 
NZ 
PL 
PT 
RO 
RU 
SD 
SE 
SG 



Lesotho 

Lithuania 

Luxembourg 

Latvia 

Monaco 

Republic of Moldova 

Madagascar 

The former Yugoslav 

Republic of Macedonia 

Mali 

Mongolia 

Mauritania 

Malawi 

Mexico 

Niger 

Netherlands 

Norway 

New Zealand 

Poland 

Portugal 

Romania 

Russian Federation 

Sudan 

Sweden 

Singapore 



SI 


Stovenia 


SK 


Sknrakia 


SN 


Senega] 


sz 


Swaziland 


TD 


Chad 


TG 


Togo 


TJ 


Tajikistan 


TM 


Turkmenistan 


TR 


Turkey 


XT 


Trinklad and Tobago 


UA 


Ukraine 


VG 


Ugaiula 


US 


United States of America 


UZ 


Uzbekistan 


VN 


Vict Nam 


YL 


Yugoslavia 


ZW 


Zimbabwe 



INTERNATIONAL SEARCH REPORT 



A. CLASSIFICATIOM OF SUBJECT MAI IfcH 

IPC 6 H04L29/O6 



Intema^-nal App<ieatten No 

PCT/oS 98/19451 



B. FEIOS SEARCHED - . 



IPC 6 HG4L 

Ctecun»nt-ion»«--doa«lh»mmin«mdooum«rt^ 

.^.»h<Miii.atd «l«lM«««nd. whf p wli ail, »— t ohtonmuMd) 

ElMSsrae^tBbuaeamutoddunngttia mt»nwfcon«i ••aren »nw- 



1 C DOCOICMTS CONSIDERED TO BE RELEVANT 



Category* 
X 

Y 



OtAtion of ckieunwnt « 



EP 0 797 342 A (SONY CORP) 24 September 
1997 

see abstract 



line 5 - page 3, line 28 
line 10 - page 5» line 1 
line 15-27 
line 36-50 

line 21 - page 8, line 18 
line 48 - page 9, line 45 
see page 10, line 46 - page 11, line 16 
see figures 1,4,5,7,8,13 



see page 2, 
see page 4, 
see page 5, 
see page 6, 
see page 7, 
see page 8, 



RctwanttDotaimNo. 

1,2,11, 
21,22, 
33,34 
3,4.23, 
24,31.32 



I Rifttwrdooifmnto «» W^* in th« oontmuation of box C. 

I o SpMial ealtgomt of eit«d dooumontB : 

•A- docun»r!tdtftnifigthog«»«i»i«teteofth« art whioh » not 

oon«dor»d to b« of partioutaf i»tov«nc» 
•E- eaifier«tooumontbulpiibl»h«*onor«fterth« ifttom«bonaJ 

fiimg data 

V dooumontwhkrftm«ymrtw doubt! on pri^ 

which it oited to >»t«tafoh tho P^t»^o"^ 
oitabon or othor tpaoi** rMon («» •P«Mh«i) 

•O- document mfwfing to «n oral diwrfowro, um, «hibftion or 
eth«r means 

•P- dooum«itpubl»hadpriortDtha«tamatkm^ filing date but 
lotarthan the priofity date oiarod 



Ptftent family nneirt>era ara listed in annex. 



T taterdocumert published aftarttwinter^^ 

or priority date and not in oonffictwHh the "PJ^wf*"™* 
Sedtoindermtandtheprinciplaortheory underiyingthe 
invention 

•X- document of particular feiavanos; the olai^^ 

eannot be considered '^t^;?^^^ 
invohfe an inventive step whan the dooument* taken akme 

•V document of particular relevance; the claimed mvwilion 
^ SbecSn2der««tDimrc*ve«.im.er^ 
document is combined with one or more other 
menta, such combination being obvious to a person stalled 
in the art 

document member of the samei>atent family 
Date of maiitng of the intemationai search report 



24 February 1999 



[Name and maiiing address of the ISA 

Bimpean Patent Offtoe, P.B. S818 Patentlaan 2 
NL • 2280 HV R^swi^ 
TaL (♦SI-TO) 340.2040, Tx. 31 651 epo nl, 
Fax: <+31-70) 340-3016 

Form PCrnSAmO (s«xind ttaet) (JuV 1992) 



2 3. 07. 99 



Authorized officer 



Li evens, K 



page 1 of 2 



INTERNATIONAL SEARCH REPORT 



Intefnatf-^l AppllcaUon No 

PCT/ui 98/19451 



C4Contlmi«tloo) OOCUUENTS COMS«)ERH) TO BE RELEVANT 

US 4 971 407 A (HOFFMAN PHILIP M) 20 
November 1990 c n«« w 

see column 1. line 8 - column 5, line 52 
see colunr 13, line 60 - column 14, line 
14 

AJAY BAKRE ET AL: M-TCP: INDIRECT TCP 
FOR MOBILE HOSTS" 
PROCEEDINGS OF THE INTERNATIONAL 
CONFERENCE ON DISTRIBUTED COMPUTIN 
SYSTEMS, VANCOUVER, MAY 30 - JUNE 2. 1995, 
no. CONF. 15, 30 May 1995, INSTITUTE OF 
ELECTRICAL AND ELECTRONICS ENGINEERS, 
pages 136-143, XP000530804 
see abstract i oc 

see page 136, right-hand column, line 1-26 
see page 137, left-hand column, line 17 - 
page 138. right-hand column, line 20 



Ftotevant to cUum No. 



3,4.23, 
24,31,32 



1,21 



FoimPCT/ISA«10(oom«iuBiono(tMond«»««)(*itV 



page 2 of 2 



INTERNATIONAL SEARCH REPORT 



tntai..at»nal apqiocbon No. 

PCT/US 98/19451 



BMl ofaMtv«tloit«»rttw»c«rtodaim««wi»loundun«««rch«bte(^^ 



Tht» 



lrt«ii-»n«l S.-* Hiport h» not l»« -Ublirt-d in r-.p«^ 



□ 



te^lTm^ i»l«t« to sufaiMt m«tt«r not p»quirKl to bo Marehod by thb Authority, n«mo*y : 



^' D SSirmi^i^itotop«t.oflttointwn«ti^ 

an ojlent thii no moinmgtui Ifilwiwtkmal Soaroh o«n bo 



Box tl Obowvationo whof* unily of tnvontloii is lacking (Continuatioci of ttom 2 of firot shoot) 



This Jntomatiooal Soifohing Authority found muttiplo invwitioni in this irtoniationsl sppBoation, as telows: 

see additional sheet 

1. I — I Asaflf»quifodadda»nal8oaroh»aaswerotimo»ypakJbytho«^ 

2. rn As all taarchahiadaimacouW bo seamhad without effort justifying an 
— of any additional foo. 

3 I — I As only soma of tho requirad additional saarch faas were timely paid by the appticant. this International Search Report 
I I covers only those daims for which fees were paid, spaaficailyciaimsraos.: 



4 No required additional saansh fees were timely paid by the applicant. Consequently, this International Search Report is 

'-X-J »«tncted to the invention first mentioned in the daima; it is covered by daims Nos. : 



restricted to the 

l-441,21-24, 31-33, 34 



Remark on Pnrtaat Q The additional seareh fees were aooompanied by the applioanf a protaat 

j [ Mo protest accompanied the payment of additional search fees. 



Form PCT/ISA/21 0 (continuation of fiiat sheet (1 )) (Ju»y 1 998) 



IrtemationalApplicalionNo. PCT/US 98/1 9451 

FURTHER INFORM ATION CONTINUED FROM PCT/ISA/ 210 

1. Claims: 1-4.11,21-24.31-33.34 
Method and system for compressing data. 

2. Claims: 1,5,12-20,21,25 
Method and system for handling multiple Internet requests in 
parallel . 

3. Claims: 1,6,21.26 
Method and system for storing a user profile for customising 
Internet data. 

4. Claims: 1,7,21,27 
Method and system for upgrading the Internet terminal. 

5. Claims: 1,8,21,28 
Method and system for off-line processing. 

6. Claims: 1,9,21,29 
Method and apparatus for caching conmonly used information. 



7. Claims: 1,10,21,30 

Method and apparatus for keeping track of charges. 



INTERNATIONAL SEARCH REPORT 

ti nation on patMit family members 



Patent document 
dted in search report 



PufalioaHon 
date 



lntemat*-fi«l Appticalion No 

PCT/wS 98/19451 



Patent family 
memt)ert9) 



Publication 
date 



Ponn PCT/!3A«10 (paord tmntf «nnu) 1892) 



PCT 



WORLD INTCLLECTUAL PROPERTY ORGANIZATION 
Intemabonal Bureau 




INTERNATIONAL APPUCATION PUBUSHED UNDER THE PATENT COOPERATION TREATY (PCT) 



(51) International Patent Classification ^ : 
H04L 29/06 



A3 



(11) international Publication Number: WO 99/19988 

(43) International Publication Date: 22 April 1999 (22.04.99) 



(21) International Application Number: PCT/US98/I9451 

(22) International Filing Date: 17 September 1998 (17.09.98) 



(30) Priority Data: 
08/948^34 



9 October 1997 (09.10.97) 



US 



(71) AppUcant: INFOGEAR TECHNOLOGY CORPORATION 
[US/US]; Suite 200, 2055 Woodside Road, Redwood City, 
CA 94061 (US). 

(72) Inventors: BENDELAC. Chaim; Yckutiel Adam Street lb. 
44282 Kfar-Saba (IL). BTITMAN. Ran, M.; Hataiesct 
Hagdola Street 20, 62917 Tel Aviv (IL). SAMBURSKI, 
Kobi; Ig*al Alon Street 30b, 46324 Hcizliya (IL). 

(74) Agents: GLENN. Michael, A. et al.; Law Offices of Michael 
A. Glenn, P.O. Box 7831, Menlo Park, CA 94026 (US). 



(81) Designated States: AL, AU, BA, BB, BG. BR, CA. CN, CU, 
CZ. EE, GE, HR, HU, ID. IL, IS. P, KP. KR, LC, LK, LR, 
LT, LV, MG, MK, MN, MX, NO, N2. PL, RO. SG, SI, SK, 
SL, TR. TT, UA, U2. VN, YU. ARIPO patent (GH, GM, 
KE, LS. MW, SD, S2. UG, ZW), Eurasian patent (AM. A2, 
BY, KG, KZ, MD. RU, TJ, TM), European patent (AT. BE, 
CH, CY, DE, DK. ES. H, FR, GB. GR. IE, TT, LU. MC, 
NL, PT, SE). OAPI patent (BF, BJ, CF. CG, CI, CM, GA, 
GN, GW, ML, MR, NE. SN. TD. TG). 



Published 

With international search report. 
With amended claims. 

(88) Date of publication of the international search report: 

10 September 1999 (10.09,99) 

Date of publication of the amended claims: 

21 October 1999 (21.10.99) 



(54) TOe: METHOD AND SYSTEM FOR NETWORK ACCESS OVER A LOW BANDWIDTH LINK 

'22 




IPhone 
client 
terminal 



GWIP 
Protocol 



GW Architecture 



(57) Abstract 

A method and system are provided for transmitting information from a faster network to a data teraiinal via a slower network 
connection. The invention is adapted for use with any Internet access device or terminal, such as an liitemet-compatible telephone. A 
client connects to the bwemct via an intermediary software program, known as the Gateway (GW). In the preferred embodiment of the 
invention, the GW executes on a host computer of an ISP's Local Area Network (LAN). The GW thus mediates the data transfer between 
the Internet, such as the We"b, and the client Internet tenninal. The GW employs a point-to-point Internet protocol, the Gateway Interface 
Protocol (GWIP) to communicate with the client over the low-bandwidth link. The invention shifts the entire overhead of the Internet 
protocol stack to the GW, and does not involve the Internet tenninal or the slow link between Internet terminal and GW. The GW makes 
and negotiates multiple Internet requests, in parallel, and multiplexes the resulting data streams, allowing documents to be loaded in parallel 
with their associated images. The GW may also be used to conveniently customize or upgrade the Internet terminal. The GW peifonns 
off-line services and caches commonly used information fetched from the Internet. The invention is also readily adapted for use with 
Internet access devices that require different document formats. 



FOR THE PURPOSES OF INFORMATION ONLY 
Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCT. 



AL 


Albania 


ES 


Spain 


LS 


Lesotho 


SI 


Slovenia 


AM 


Amienia 


FI 


Finland 


LT 


Lithuania 


SK 


Slovakia 


AT 


Austria 


FR 


France 


LU 


Luxembourg 


SN 


Senegal 


AU 


Austialia 


GA 


Gabon 


LV 


Latvia 


sz 


Swaziland 


AZ 


Azeibaijan 


GB 


United Kingdom 


MC 


Monaco 


TD 


Chad 


BA 


Bosnia and Herzegovina 


GE 


Georgia 


MD 


Republic of Moldova 


TG 


Togo 


BB 


Bartiados 


GH 


Ghana 


MG 


Madagascar 


TJ 


Tajikistan 


BE 


Belgium 
Buricina Faso 


GN 


Guinea 


MK 


The former Yugoslav 


TM 


Turkmenistan 


BF 


GR 


Greece 




Republic of Macedonia 


TR 


Turkey 


BG 
BJ 


Bulgaria 
Benin 


HU 
IE 


Hungary 
IreUnd 


ML 
MN 


Mali 

Mongolia 


TT 
UA 


Trinidad and Tobago 
Ukraine 


BR 


Brazil 


IL 


Israel 


MR 


Mauritania 


UG 


Uganda 


BY 


Belanis 


IS 


Iceland 


MW 


Malawi 


us 


United States of America 


CA 


Canada 


IT 


Italy 


MX 


Mexico 


uz 


Uzbekistan 


CF 


Central African Republic 


JP 


Japan 


NE 


Niger 


VN 


Vict Nam 


CG 


Congo 


KE 


Kenya 


SL 


Netherlands 


. YU 


Yugoslavia 


CH 


Switzerland 


KG 


Kyrgyzsian 


NO 


Norway 


zw 


Znnbabwe 


a 


CAce d*lvotre 


KP 


Democratic People's 


NZ 


New Zealand 






CM 


Cameroon 




Republic of Korea 


PL 


Poland 






CN 


China 


KR 


Republic of Korea 


FT 


Portugal 






cu 


Cuba 


KZ 


Kazakstan 


RO 


Romania 






cz 


Czech Republic 


LC 


Saint Lucia 


RU 


Russian Federation 






DE 


Germany 


U 


Liechtenstein 


SD 


Sudan 






DK 


Denmaric 


LK 


Sri Lanka 


SE 


Sweden 






EE 


Estonia 


LR 


Liberia 


SG 


Singapore 







wo 99/19988 



PCT/US98/194S1 



AMENDED CLAIMS 

[received by the International Bureau on 24 August 1999 (24.08.99); 
original claims 1-34 replaced by amended claims 1-25 (4 pages)] 

1. A method for accessing network information during a communications session, 

comprising the steps of: 

accessing a host via a slow link using an Internet terminal; 

the host negotiating an Internet connection on behalf of said Internet terminal with a 
software application integrated into said host; 

said software application using an interface protocol to transfer data from said Internet 
connection to and from said internet terminal, thereby mediating data transfer between the 

Internet and said Internet terminal; 

said software appUcation filtering said Internet data from said Internet connection to 

reduce the amount of data that is irrelevant to said Internet terminal's attributes; 

said software application stripping redundant characters from said Internet data; and 
said software appUcation converting said Internet data to a compressed equivalent data 

format 

2. The method of Claim l.ftmher comprising the steps of. 

said software appUcation using said interface protocol to make and negotiate multiple 

Internet requests, in parallel; 

said software appUcation parsing and forwarding said requests to an Internet server for 

execution; 

said software appUcation filtering data received from the Internet in response to said 
request and according to file type; and 

said software application multiplexing said filtered data over said slow link to said 

Internet terminal. 

3. The method of Claim 1, further comprising the steps of: 

said Internet terminal storing a profile of a user of said Internet terminal; and 
said software appUcation using said profile to customize said Internet data sent to said 
internet terminal. 

4. The method of Claim 1. further comprising the step of said software application using 
said interface protocol to upload data to upgrade said Internet teraoinal. 

5. The rnethod of Claim 1 . wherein said software appUcation is an off-line agent for said 
Internet terminal. 

25 
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idonMUon conmonly used by said Internet tenmnal. 

, The .nethod of Oai. 1. tather comprising the step of said softw^^piic-n 
:ha.,es^ingtosaidIntemettettni„aiasatcs..cofsaidInten>«connecuon. 

The .nethod o, aain, U wherein said in«n.et tenninal is an Intemet^ompaUble 

telephone. 

A n^ethod for accessing networic infom^tion during a co—tions session, 

comprising the steps of: .,™i„,i. 

■ ..hM. via a slow link using an Internet terminal, 
accessmg a host via a slo» unit us s ..^nai-. an Internet connection on 

a software appUcation integrated mto said host negotiating 

'^l^S^onusinganinterfaceprotocoitotransferdata^msaid.te^^ 

— sctr:^^:^^-----"--^-^'"^^^ 

'"'™^"S^lC--onparsingandforw,rdingsaidre,,uests.o^ 

'^"1 software application filtering data received f^m the ,nt«net in response ,o said 
'^'"'^d°Sl%rtionr=ducing,heamountofsaidInternetdatathatUi,«^^^^^ 

-d ratered data over said siow iin. to s.d 

'°^":'::tareappUcado„s^pp,ngredundan.chara^rsfroms.^^^^ 

said software appUcadon converdng said Internet data to a compressed equivalent 



format 



10 The method ofOaim 9. further comprising the steps oft 

^dlntemetterminalstoringaprofileofauserofsaidlnt^ne.^.^ 
said software application using said profile to customize said Internet data 

Internet tenninal. 
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U Themeth of Claim 9. ftirther compnsing the step of s. software application usmg 
said interface protocol to upload data to upgrade said Inten^et terminal. 

12, The method of Claim 9. wherein said software application is an off-Une agent for said 
latcmet terminal. 

13. The meU>od of Claim 9, tohcr comprising step of s^d sofnv« application caching 
information commonly used by said imemet tenninal. 

,4 TT„med,odofaaim9.ted«rcomprisingfl«s»pofsaidsofnva«appUcadoo«clan^ 
^acc™ng<os«duscrofsaidIn,e«c.«nmnal.sa:.»a,ofsaidl«cmctco»^^^ 

15. Tb= method of Qaim 9, .-h«ein said Internet temunal is an Intemet^ompatible 

telephone. 

16. A system tor accessing nemork information during a commnmcations session. 

comprising: ,. , ^ 

an Internet terminal for accessing a host via a slow link;and 

a software appUcation integrated into said host for negotiating an Internet comtecuon on 

behalf of said Internet tenninal; . ^ r 

wherein said software application uses an interface protocol to t^nsfer data from satd 

Internet connection to and from said Internet tenninal; 

a stripping module in said software appUcadon for stripping r«iundant characten ftom 

^''"'tr.^stnmod^einsaidsoftwareapp.icaticnforconv.ningsaid.n.emetdata^^ 

compressed equivalent data format 

,7 The system of Claim 16. further comprising a filtering module in ^^f^Z 
appUcadon for filtering said Internet data from said Intemet connecdon to smp out data that .s 
irrelevant to said Internet appUance's attributes. 

18 The system of Qaim 16. ftirther comprising: 

■ a parallel request module in said software appUcation for using said interface protocol to 
make and negotiate multiple Internet requests, in paraUel; 

a parsing module in said software appUcation for parsing and forwarding said requests 
to an Internet server for execution; 
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a file typ .lodule in said software application for filt. .ng^da-ta received from the 
Internet in response to said request according to file type; and 

a mtiltiplexer module in said software application for multiplexing said fUtered data over 

said slow link to said Internet terminal. 

19. The system of Claim 1 6. further comprising: 

a storage module in said Internet terminal for storing a profile of a user of said Internet 

terminal; and 

a customizing module in said software appUcation for using said profile to customize 
said Internet data sent to said Internet teraoinal. 

20. The system of Claim 16. fiirther comprising an upgrade module in said software 
appUcation for using said interface protocol to upload data to upgrade said Internet terminal. 

21. The system of Claim 16. wherein said software appUcation is an off-line agent for said 
Internet terminal 

22. The system of Claim 16. fiirther comprising a cache in said software application for 
caching information commonly used by said Internet terminal. 

23. The system of Claim 16. further comprising a tracking module in said software 
application for tracking charges accruing to said cUent as a result of said Internet connection. 

24. The system of Claim 16. wherein said Internet terminal is an Internet-compatible 
telephone. 

25. An access terminal, comprising: 

an Internet-compatible telephone for receiving and displaying a Web page; 
a software appUcation integrated into an Internet Service Provider for connecting said 
Internet-compatible telephone to die Internet; 

wherein said software application mediates dau transfer between the Internet and said 

Internet-compatible telephone; 

a stripping module in said software application for stripping redundant characters from 

said Internet data; and 

a compression module in said software appUcation for converting said Internet data to a 
compressed equivalent data format 
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